import router from '@/router'
import store from '@/store'
import NProgress from 'nprogress' // 引入一份进度条插件
import 'nprogress/nprogress.css' // 引入进度条样式

// 路由前置守卫
const whiteList = ['/login', '/404'] // 白名单
router.beforeEach(async(to, from, next) => {
  NProgress.start() // 开启进度条
  // 判断有无token
  if (store.getters.token) {
    // 有并且跳转去登录页，直接来到首页
    if (to.path === '/login') {
      next('/')
    } else {
      // 如果没有userId就调用getUserInfo，获取用户资料
      if (!store.getters.userId) {
        await store.dispatch('user/getUserInfo')
      }
      // 没有跳转到登录页就直接放行
      next()
    }
  } else {
    // 没有token但在白名单，直接放行
    if (whiteList.indexOf(to.path) > -1) {
      next()
    } else {
      // 没有token又不在白名单，直接跳转到登录页
      next('/login')
    }
  }
  NProgress.done() // 手动结束进度条
})

// 后置守卫
router.afterEach(() => {
  NProgress.done() // 结束进度条
})
